#!/bin/sh
# create -v3 logs and dxf's with dwg2dxf/dxfwrite
srcdir="@srcdir@"
top_builddir="@top_builddir@"
CFLAGS="@CFLAGS@"
timeout="@TIMEOUT_30@"

case "$CFLAGS" in
    *-DDEBUG_CLASSES*) timeout= ;;
    *) ;;
esac
make -s -C src
make -s -C programs dwg2dxf dxfwrite
@DSYMUTIL@ programs/dwg2dxf programs/dxfwrite
v=-v3
# dummy to please shellcheck
test -z "$v" && echo $top_builddir
args=-y
out=

for d in "$@"; do
    case $d in
        -v*)    v="$d"    ;;
        --as=*) args="$args $d" ;;
        -m)     args="$args $d" ;;
        -b)     args="$args $d" ;;
        -Ijson) ext=json  ;;
        -Idxf)  ext=dxf   ;;
        -y)     ;;
        *)
        if [ ! -f "$d" ]; then
            if [ -f "$srcdir/test/test-data/$d" ]
            then
                d="$srcdir/test/test-data/$d";
            elif [ -f "$srcdir/test/test-data/$d.dwg" ]
            then
                d="$srcdir/test/test-data/$d.dwg"
                ext=dwg
            elif [ -f "$srcdir/test/test-data/$d.json" ]
            then
                d="$srcdir/test/test-data/$d.json"
                ext=json
            elif [ -f "$srcdir/test/test-data/$d.dxf" ]
            then
                d="$srcdir/test/test-data/$d.dxf"
                ext=dxf
            fi
        fi
        xd=$(dirname "$d")
        dir=_$(basename "$xd")
        if [ "$dir" = "_test-data" ]; then dir=""; fi
        if [ "$dir" = "_td" ]; then dir=""; fi
        if [ "$dir" = "_." ]; then dir=""; fi
        case $(basename "$d") in
            *.dwg)  ext=dwg ;;
            *.DWG)  ext=dwg ;;
            *.dxf)  ext=dxf ;;
            *.DXF)  ext=dxf ;;
            *.json) ext=json ;;
            *.JSON) ext=json ;;
            *)      echo "Illegal extension for $d"; exit ;;
        esac
        b=$(basename "$d" .$ext)
        log="$b$dir.log"
        out="$b$dir.dxf"
        if [ x$ext = xdwg ]; then
            echo "$timeout @LTEXEC@ programs/dwg2dxf $args $v -o $out $d 2>$log"
            # shellcheck disable=SC2086
            $timeout @LTEXEC@ programs/dwg2dxf $args "$v" -o "$out" "$d" 2>"$log"
        else
            echo "$timeout @LTEXEC@ programs/dxfwrite $args $v -o $out $d 2>$log"
            # shellcheck disable=SC2086
            $timeout @LTEXEC@ programs/dxfwrite $args "$v" -o "$out" "$d" 2>"$log"
        fi
        tail -n2 "$log"
        ;;
    esac
done
